**PRACTICAL 9**

**COMPUTER ORGANISATION AND ARCHITECTURE**

|  |  |
| --- | --- |
| **NAME: VARUN KHADAYATE** | **ROLL NO: A016** |
| **PROGRAM: BTECH SY** | **DIVISION: CSBS** |
| **BATCH: 1** | **DATE OF EXPERIMENT: 27/10/2020** |

**AIM**

**Understanding the behaviour of associative cache from working module and designing an associative cache for given parameters**

**THEORY**

**Design of Associative Cache:**

Cache memory is a small (in size) and very fast (zero wait state) memory that sits between the CPU and main memory. The notion of cache memory relies on the correlation properties observed in sequences of address references generated by CPU while executing a program (principle of locality). When a memory request is generated, the request is first presented to the cache memory, and if the cache cannot respond, the request is then presented to the main memory.

* **Hit:**  cache access finds data resident in the cache memory
* **Miss:**  cache access does not find data resident, so it forces to access the main memory.

Cache treats the main memory as a set of blocks. AS the cache size is much smaller than the main memory, so the number of cache lines is very less than the number of main memory blocks. So, a procedure is needed for mapping main memory blocks into cache lines. The cache mapping scheme affects cost and performance. There are three methods in block placement-

* **Direct Mapped Cache**
* **Fully Associative Mapped Cache**
* **Set Associative Mapped Cache**

**Associative Cache**

Any main memory block can map into any cache line. the main memory address is divided into two groups which are tags and word bits. Words are low-order bits and identify the location of a word within a block and tags are high-order bits that identify the block.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUoAAABQCAYAAAB/EzxMAAAAAXNSR0IArs4c6QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAMTQAADE0B0s6tTgAAAAd0SU1FB9wGGwkVCeDINvUAAAMJSURBVHja7d1LbqswAAXQuGL/W3ZHSBQZ/4AUm3OkN3iEUhqcm+tAS4gxfgA4tngKgKcIIcTP5/OJMYaa9ba2X5N6PLVerR+HBhgxTGuX966nUQLDSzXIEELcLt+3x56Q/BOU2w3kNl6qty071lOBAVJZ0huCt069z9bfM+kOEEKI+xJXU756CtpytAPrxkphVlN/r6zAgPa4z5u7c+bnjh8A4BuBuW+RNcG4b6LdjbJnCr7ubEtYClbgqtCsOWfS2zKXmm94tKy2/ppqA1epvdbySktpZ1paYe4zyqf8wMA4YZhrh2euumnNnEuvo8ydotcygW9Ps68IyVNBqQ0Cd4TgFetdnUtLKbHP/s7l1RUY4Nu6Lw86CjhnvYHZBH9mDeCmRgkgKAEQlACCEkBQAghKAEEJICgBBCWAoAQQlAAISgBBCSAoAQQlwDMtd27cPXGA0cUYw/KNb+Kp5o1q70bKs4+hqTdABUEJICgBBCWAoAQQlACCEkBQAghKAEEJgKAE6LF4Cv5X7R8O8TvDoFECaJTUNcW1YWqQICi5cKqeCtXtejHGkArg2m2BqTdDh2Rqeen/Ldvi+WNi/Xf0WO3yO/dPo+Rfp+u5UFzXyw3UUsPk+WOh5Y0QjfIVL4raqfF2vdzX7IPV1HvumYgA1ShfPf0+00RSLZQxx8aZ47cfW7kTjUcnHWcdSxrlgCG5Nr+zAzG1HY1jzJlGy/JSwJXGQu9n5YKSoaZbqRMAmuScx77muOY+fjkKu9x6M36EIygHfSEcnU3cD97adTTJ94RnTctsaaM92xCUfG2KlXtHLw3snukac4SlY9zOyZyHh2FLWLYGnhfMXOPGzECjpHFa3jrt4l1vuKXpee+YmfVSJI1y8mmWBsnRRempx0uXCPVsQ6NkmCYhJLXI1vHROmZqPxYasnjEeF/4n70AFkZv9cb/HMdQowQw9QYQlACCEkBQAghKAEEJICgBBCUAghJAUAIISgBBCSAoAQQlgKAEEJQAbNx+zxw3tuLNjP9JjuOdt4IAmMEvRdk037zFOb4AAAAASUVORK5CYII=)

Block diagram of an associated cache:

![](data:image/png;base64,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)

If a miss occurs CPU brings the block from the main memory to the cache, if there is no free block in the corresponding set it replaces a block and puts the new one. CPU uses different replacement policies to decide which block is to replace. The disadvantage of the associative cache is its high cost for implementing parallel tag comparison but suffer the most from thrashing due to the 'conflict misses' giving more miss penalty.

**Design issues:**

No replacement policy has been implemented in the experiment.

The comparator circuit through which tag is compared with specified bits of address:

![](data:image/png;base64,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)

**PROCEDURE**

**Design of Associative Cache:**

**Procedure to experiment with associative cache on the existing component 'Associative Cache' component in the 'other components' drawer in the simulator. This simulator supports 5-valued logic.**

1. Click on the 'Associative Cache' component(in the 'other components' drawer in the pallet) and then click on the position of the editor window where you want to add the component(no drag and drop, a simple click will serve the purpose), likewise add 15 Bit switches and 3 Bit Displays(from Display and Input drawer of the pallet, if it is not seen scroll down in the drawer)
2. The 'Associative Cache' component in the 'other components' drawer in the simulator supports both writings in the cache and the cache mapping. No replacement policy has been implemented. Initially, the cache is empty, the user must give inputs. the component contains 4 sets, each set has 5 bits, the leftmost bit is the valid bit, the next 2 bits are tags, the next bits are data bits, also it contains a one-dimensional array of memory with 2 bit to store the memory address, the user has to give this address input also. The cache reads all the data bits at a time so block offset is not required.
3. The pin configuration of the component can be seen whenever the mouse is hovered on any canned component of the palette or press the 'show pin config' button. Pin numbering starts from 1 and the bottom left corner (indicating with the circle) and increases anticlockwise.
4. For an 'Associative Cache' component pin configuration is:
   * pin-32= S (selects whether the user wants to perform cache write or cache mapping)
   * pin-31= R/W’A (selects whether the user wants to input the address or cache mapping)
   * pin-30=A1, pin-29=A0 (these 2 pins are used to give address input). A1 is the most significant bit and A0 is the least significant bit. As we are reading the whole word at a time, the whole address will be in the tag. So, A1 and A0 will be compared with the tag. A1 and A0 will select the corresponding set.
   * pin-28= R/W’D (selects whether the user wants to input in the set of cache or cache mapping)
   * pin-27= M1, pin-26=M0 (M1 is the most significant bit and M0 is the least significant bit). these two bits are used for cache write purpose, it selects the particular set of which user wants to give inputs to the valid bit, tag bits, and data bits.
   * pin-21= valid bit
   * pin-20= T1, pin-19=T0 (T1 is the most significant bit and T0 is the least significant bit). These are tag bits.
   * pin-18= D1, pin-17=D0 (D1 is the most significant bit and D0 is the least significant bit). These are data bits.
   * pin-14= Hit/Miss bit (if it gives 1 then hit otherwise miss)
   * pin-15= F1, pin-16=F0 (F1 is the most significant bit and F0 is the least significant bit). These are output data bits and will be given only when there is a hit.
5. **Essential pin configurations for writing in the cache: S=1, R/W'A=0, R/W'D=0**
6. **Essential pin configurations for cache mapping: S=0, R/W'A=1, R/W'D=1**
7. To connect any two components, select the Connection menu of Palette, and then click on the Source terminal and click on the target terminal. According to the circuit diagram connect all the components. After the connection is over click the selection tool in the pallet.
8. See the output, Bit switches are used to give input so that you can toggle its value with a double click and see the outputs with different inputs.

**CONCLUSION**

Hence, we can understand the behaviour of associative cache from working module and designing an associative cache for given parameters.